草庐IT

C++11 auto 和 size_type

全部标签

c++ - 静态数组 VS。 C++11 中的动态数组

我知道这是一个非常古老的争论,已经在全世界讨论过很多次。但是我目前在决定在特定情况下应该使用哪种方法而不是静态和动态数组之间的另一种方法时遇到麻烦。实际上,我不会使用C++11,我会使用静态数组。但我现在很困惑,因为两者可能有相同的好处。第一种解决方案:templateclassFoo{private:intarray[N];public://Somefunctions}第二种方案:templateclassFoo{private:int*array;public://Somefunctions}我不能碰巧选择,因为两者各有优势:静态数组更快,我们根本不关心内存管理。只要没有分配内存,

C++11 move 构造函数有副作用

在C++中,不能依赖从return语句调用的复制构造函数,因为标准中的一个特殊子句允许编译器忽略对由return语句产生的复制构造函数的调用,即使复制构造函数具有副作用。因此,编写一个除了复制构造实例之外还做其他事情的复制构造函数是一种糟糕的风格。C++11标准中是否有类似的语句允许编译器在某些情况下消除对move构造函数的调用-如果有,那是什么情况? 最佳答案 copy-elision同样适用于moveconstruction,是同一个子句,copyconstruction和moveconstruction的省略统称为“copy-

c++ - 'must have an argument of class or enumerated type'到底是什么意思

我有一个头文件和一个.cpp文件。我需要为我的.h文件编写函数,但在我完全完成骨架.cpp文件之前出现错误。金钱.h#ifndefMONEY_H#defineMONEY_H#include#includeusingnamespacestd;classMoney{public:Money(intdollars,intcents);Moneyoperator+(constMoney&b)const;Moneyoperator-(constMoney&b)const;Moneyoperator*(doublem)const;Moneyoperator/(doubled)const;voidp

数据结构—基础知识(11):二叉树的遍历

数据结构—基础知识(11):二叉树的遍历二叉树的遍历二叉树的遍历是指按某条搜索路径访问树中每个结点,使得每个结点均被访问一次,而且仅被访问一次。由于二叉树是一种非线性结构,每个结点都可能有两棵子树,因而需要寻找一种规律,以便使二叉树上的结点能排列在一个线性队列上,进而便于遍历。由二叉树的递归定义可知,遍历一棵二叉树便要决定对根结点N、左子树L和右子树R的访问顺序。按照先遍历左子树再遍历右子树的原则,常见的遍历次序有先序(NLR)、中序(LNR)和后序(LRN)三种遍历算法,其中“序”指的是根结点在何时被访问。先序遍历:ABCDEFGH中序遍历:BDCEAFHG后序遍历:DECBHGFA先序遍历

c++ - 为什么专门化 type_trait 会导致未定义的行为?

讨论根据标准§20.10.2/1Header概要[meta.type.synop]:1Thebehaviorofaprogramthataddsspecializationsforanyoftheclasstemplatesdefinedinthissubclauseisundefinedunlessotherwisespecified.这个特定的子句与STL应该是可扩展的一般概念相矛盾,并阻止我们扩展类型特征,如下例所示:namespacestd{templatestructis_floating_point>:std::integral_constant::type>::value

c++ - 如何在 C++11 中以毫秒为单位打印当前系统时间?

我在获取以毫秒为单位的实际系统时间时遇到了问题。我发现的唯一一个好方法是在Windows.h中,但我不能使用它。我应该使用std::chrono。我该怎么做?我花了很多时间尝试用谷歌搜索它,但我只找到了二精度的例子。我正在尝试获取这样的字符串:[2014-11-2522:15:38:449] 最佳答案 使用thisanswer中的代码:#include#include#includetemplatevoidprint_time(tmt,Durationfraction){usingnamespacestd::chrono;std::

c++ - C++11、14 或 17 是否提供了一种从 decltype() 中获取参数的方法?

这个问题非常类似于:“Extractjusttheargumenttypelistfromdecltype(someFunction)”。我不确定那里的答案是否适合我的意图。我希望能够创建一个模板函数,该函数根据函数指针模板参数(whiSTLes)的类型推断其运行时参数的类型。举一个示例用例,假设我想使用加载了LD_PRELOAD的垫片库来检测直接CPOSIX文件I/O。我可以为fopen、fread、fwrite、fclose编写单独的包装器……如果所有这些包装器都做类似的事情,如果我可以定义一个捕获常见行为的模板不是很好吗?不使用模板的部分示例演示了涉及多少样板文件:extern"

解决win11安装node后npm报错 \node_modules\npm\bin\npm-cli.js“ prefix -g‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件。

解决win11安装node后npm报错\node_modules\npm\bin\npm-cli.js"prefix-g’不是内部或外部命令,也不是可运行的程序或批处理文件。电脑正常安装node后,查看安装是否成功,分别运行node-vnpm-v结果node正常,npm却提示有问题报错\node_modules\npm\bin\npm-cli.js"prefix-g’不是内部或外部命令,也不是可运行的程序或批处理文件。然后就是一顿检查,环境变量,但是始终没有找原因,只能求救度娘,几经百度最后终于找到一个有用的办法,现记录如下其实很简单只要,把环境变量里【ComSpec的变量值】删除npm就能正

c++ - 将 const 添加到 size_t 会导致编译失败是标准行为吗?

我最近读了一篇很酷的文章:https://akrzemi1.wordpress.com/2015/08/20/can-you-see-the-bug/在ideone上玩简化版时,我得到了令人惊讶的行为:#include#includeusingnamespacestd;intmain(){constsize_tsz=258;strings{sz,'#'};assert(2==s.size());}不编译,但是删除const的相同程序编译:#include#includeusingnamespacestd;intmain(){size_tsz=258;strings{sz,'#'};as

c++ - 我可以在 C++11 中使用具有值语义的多态容器吗?

这是relatedpost的续集提出了永恒的问题:CanIhavepolymorphiccontainerswithvaluesemanticsinC++?问题问得有点不对。它应该更像是:CanIhaveSTLcontainersofabasetypestoredby-valueinwhichtheelementsexhibitpolymorphicbehavior?如果您问的是C++方面的问题,答案是否定的。在某些时候,您将对按值存储的对象进行切片。现在我再次提出这个问题,但严格按照C++11。随着语言和标准库的变化,现在是否可以在STL容器中按值存储多态对象?我很清楚在容器中存储指